草庐IT

future 类型更改的 Java 模式

全部标签

ruby-on-rails - 在 Rails 中分配和重用变量 - 设计模式

我一直在使用相同的模式来返回json代码(参见下面的示例)。我正在收集照片并将其存储在变量中。如果存在标记参数,我将获得一个更具体的集合并将其重新分配给同一个变量。然后将其作为json返回。什么是更好的设计模式来实现同样的事情?photos=collection_of_photosifparams[:tag]photos=photos.find_all{|photo|somecondition}endrenderjson:photos 最佳答案 如果照片是ActiveRecord对象,您应该使用scope为您需要的确切数据生成适当的

ruby-on-rails - 如何使用 graphql-ruby 指定多态类型?

我有一个UserType和一个可以是Writer或Account的userable。对于GraphQL,我想也许我可以像这样使用UserableUnion:UserableUnion=GraphQL::UnionType.definedoname"Userable"description"AccountorWriterobject"possible_types[WriterType,AccountType]end然后像这样定义我的用户类型:UserType=GraphQL::ObjectType.definedoname"User"description"Auserobject"fie

ruby-on-rails - 如何在正在运行的 ruby​​ 进程中更改 Date.today 的值

我知道这是个坏主意,但我有很多遗留代码,我想运行一些历史批处理作业。我不想更改系统日期,因为其他东西在同一系统上运行。有什么方法可以更改Date.today仅在给定进程的生命周期内返回的值。这里的想法是倒带并运行一些用于处理Date.today的旧批处理脚本。谢谢乔尔 最佳答案 您可以像Nikolaus向您展示的那样对Ruby进行猴子补丁,也可以使用TimeCopgem。它旨在使编写测试更容易,但您也可以在普通代码中使用它。#Setthetimewhereyouwanttogo.t=Time.local(2008,9,1,10,5,

ruby-on-rails - 更改现有应用程序的 heroku repo

我前段时间为我的Rails应用程序创建了一个heroku存储库,但由于我从未使用过它而删除了它。现在我已经到了需要使用heroku的地步,但我遇到了以下错误:!Nosuchappasfurious-mist-2295.这是旧的repo名称,所以它显然没有推送到我创建的新堆栈。这是我正在考虑尝试的方法,但我担心会对我的git存储库造成不必要的更改。gitremotermorigingitremoteaddorigingitpush-uoriginmaster 最佳答案 原来可以用下面的命令来完成gitremotermherokugit

ruby - 为什么我会看到这两个几乎相同的 Ruby 正则表达式模式的不同结果,为什么一个匹配我认为不应该匹配的内容?

使用Ruby1.9.2,我在IRB中有以下Ruby代码:>r1=/^(?=.*[\d])(?=.*[\W]).{8,20}$/i>r2=/^(?=.*\d)(?=.*\W).{8,20}$/i>a=["password","1password","password1","pass1word","password1"]>a.each{|p|puts"r1:#{r1.match(p)?"+":"-"}\"#{p}\"".ljust(25)+"r2:#{r2.match(p)?"+":"-"}\"#{p}\""}这会产生以下输出:r1:-"password"r2:-"password"r1:

ruby-on-rails - Rails 中的 Post Redirect Get 模式

如何在Rails中实现PRG?我在Rails中使用了PRG,但我并不完全相信它是正确的。我想知道在Rails中是否有更好的方法来处理它? 最佳答案 我不知道PRG模式有多流行以及为什么人们必须虔诚地坚持它的失败方面的“重定向”(实际上,一个很好的理由是有时你不想处理“设置”的复杂性制造失败并保持干燥)。您基本上需要的是将:user的参数传输到new。我认为上面@Hitesh的解决方案非常接近。classUsersController:newendendend 关于ruby-on-rail

ruby - 在 YARD 中使用多种方法记录鸭子类型

YARD允许我指定方法参数和返回值的类型。因为我真的很喜欢躲避类型,所以很高兴看到YARD还支持通过指定它们必须支持的方法来定义类型。如你所见here,像#first_method,#second_method这样的表达被解释为逻辑析取。这意味着对象需要支持#first_method或#second_method或两者。这不是我需要的。我希望能够指定一个对象需要同时支持我的参数的#first_method和#second_method。有办法指定吗? 最佳答案 没有用于指定复合鸭子类型接口(interface)的惯用语法。也就是说,

ruby - 使用 Nokogiri 进行模式验证

我正在尝试使用Nokogiri根据十几个模式验证XML文档。目前我有一个导入所有其他模式的根模式文档,我对此进行了验证。我能否从XML文件本身指向每个模式文件,并让Nokogiri在XML文件中查找模式以进行验证? 最佳答案 引用多个模式以验证XML文件的正确方法是使用schemaLocation属性:对于文档中的每个namespace,您列出了一对以空格分隔的值:namespaceURI后跟关于在哪里可以找到该namespace的架构的“提示”。如果您为每个提示提供完整的URI,那么您可以像这样使用Nokogiri进行处理:req

ruby-on-rails - 如何使用 Rspec 更改请求测试中的子域(用于 API 测试)

我有一个非常具体的问题。我不想进行Controller测试,而是进行请求测试。而且我不想使用Capybara,因为我不想测试用户交互,而只想测试响应状态。我在spec/requests/api/garage_spec.rb下有以下测试require'spec_helper'describe"Garages"dodescribe"index"doit"shouldreturnstatus200"doget'http://api.localhost.dev/garages'response.status.shouldbe(200)response.body.should_notbe_emp

具有整数键的 Ruby Hash 更改为字符串键

我使用整数键在ruby​​中创建一个散列,并将其作为JSON响应发送。然后解析此JSON,并将哈希转换回ruby​​。键现在是字符串文字。我知道JSON不支持整数键,但我想到了这个方法,它基本上解析散列,使其具有符号键。JSON.parse(hash,{:symbolize_names=>true})是否有类似的函数取回原始整数键a={1=>2}a.keys=>[1]b=JSON.parse(JSON.generate(a))b.keys=>["1"]我的散列非常复杂。该值本身是一个散列,应该具有整数键。有多个这样的嵌套层次 最佳答案